home *** CD-ROM | disk | FTP | other *** search
/ Merciful 2 / Merciful - Disc 2.iso / software / m / maxonc++2.dms / maxonc++2.adf / MCPIncl.lha / libraries / asl.h next >
C/C++ Source or Header  |  1992-01-26  |  8KB  |  230 lines

  1. #ifndef    LIBRARIES_ASL_H
  2. #define    LIBRARIES_ASL_H    1
  3.  
  4. /*
  5. **    $Filename: libraries/asl.h $
  6. **    $Release: 2.04 $
  7. **    $Revision: 36.4 $
  8. **    $Date: 91/03/06 $
  9. **
  10. **    ASL library name and useful definitions.
  11. **
  12. **    (C) Copyright 1989,1990 Commodore-Amiga Inc. and Charlie Heath
  13. **        All Rights Reserved
  14. */
  15.  
  16. #ifndef    EXEC_TYPES_H
  17. #include    <exec/types.h>
  18. #endif
  19.  
  20. #ifndef    EXEC_LISTS_H
  21. #include    <exec/lists.h>
  22. #endif
  23.  
  24. #ifndef    EXEC_LIBRARIES_H
  25. #include    <exec/libraries.h>
  26. #endif
  27.  
  28. #ifndef UTILITY_HOOKS_H
  29. #include <utility/hooks.h>
  30. #endif
  31.  
  32. #ifndef UTILITY_TAGITEM_H
  33. #include <utility/tagitem.h>
  34. #endif
  35.  
  36. #ifndef WBArg
  37. #include <workbench/startup.h>
  38. #endif
  39.  
  40. #ifndef GRAPHICS_TEXT_H
  41. #include <graphics/text.h>
  42. #endif
  43.  
  44. /*
  45.  ************************************************************************
  46.  *    Standard definitions for asl library information        *
  47.  ************************************************************************
  48.  */
  49.  
  50. #define    AslName        "asl.library"
  51.  
  52. /*
  53.  ************************************************************************
  54.  *                                    *
  55.  *    The ASL file requester data structure...            *
  56.  *                                    *
  57.  * The fields described here are for READ ACCESS to the structure    *
  58.  * returned by AllocAslRequest( ASL_FileRequest, ... )            *
  59.  *                                    *
  60.  * Any modifications MUST be done via TAGS either at the time of    *
  61.  * creation by AllocAslRequest(), or when used, via AslRequest()    *
  62.  *                                    *
  63.  ************************************************************************
  64.  */
  65. struct FileRequester    {
  66.     APTR    rf_Reserved1;
  67.     BYTE    *rf_File;    /* Filename pointer        */
  68.     BYTE    *rf_Dir;    /* Directory name pointer    */
  69.     CPTR    rf_Reserved2;
  70.     UBYTE    rf_Reserved3;
  71.     UBYTE    rf_Reserved4;
  72.     APTR    rf_Reserved5;
  73.     WORD    rf_LeftEdge,rf_TopEdge;    /* Preferred window pos    */
  74.     WORD    rf_Width,rf_Height;   /* Preferred window size    */
  75.     WORD    rf_Reserved6;
  76.     LONG    rf_NumArgs;    /* A-la WB Args, for multiselects */
  77.     struct WBArg *rf_ArgList;
  78.     APTR    rf_UserData;    /* Applihandle (you may write!!) */
  79.     APTR    rf_Reserved7;
  80.     APTR    rf_Reserved8;
  81.     BYTE    *rf_Pat;    /* Pattern match pointer */
  82.     };            /* note - more reserved fields follow */
  83.  
  84.  
  85. /*
  86.  * The following defined values are the ASL_FuncFlags tag values which
  87.  * are defined for the ASL file request.  These values may be passed
  88.  * as a TagItem to modify the way the requester is presented.  Each
  89.  * flag value defined has a description of the particular action.
  90.  *
  91.  * Also related to the ASL_FuncFlags values is the ASL_HookFunc tagitem,
  92.  * which provides a callback function pointer to allow the application
  93.  * to interact with the requester.  If an ASL_HookFunc TagItem is
  94.  * provided, the hook function will be called like so:
  95.  *
  96.  * ULONG rf_Function(ULONG Mask, CPTR Object, CPTR AslRequester)
  97.  *
  98.  * The Mask value is a copy of the specific ASL_FuncFlags value
  99.  * the callback is for; Object is a pointer to a data object.
  100.  * AslRequester is a pointer to the requester structure.
  101.  *
  102.  * For the ASL file and font requesters, two ASL_FuncFlags values
  103.  * are currently defined; FILF_DOWILDFUNC and FILF_DOMSGFUNC.
  104.  *
  105.  */
  106.  
  107. #define    FILB_DOWILDFUNC    7L /* Called with an Object=AnchorPath,    */
  108.                /*         ZERO return accepts.    */
  109. #define    FILB_DOMSGFUNC    6L /* Called with Object=IDCMP message    */
  110.                /*  for other window of shared port. */
  111.                /* You must return pointer to Object,*/
  112.                /* asl will reply the Object for you */
  113. #define    FILB_SAVE    5L /* For a SAVE operation, set this bit */
  114. #define    FILB_NEWIDCMP    4L /* Force a new IDCMP (only if rf_Window != NULL)  */
  115. #define FILB_MULTISELECT 3L /* Request multiple selections returned from FR. */
  116.                /*    MULISELECT is ignored if FILB_SAVE is on     */
  117. #define    FILB_PATGAD    0L /* Ask for pattern gadget                 */
  118.  
  119.  
  120. #define    FILF_DOWILDFUNC    (1L << FILB_DOWILDFUNC)
  121. #define    FILF_DOMSGFUNC    (1L << FILB_DOMSGFUNC)
  122.  
  123. #define    FILF_SAVE    (1L << FILB_SAVE)
  124. #define    FILF_NEWIDCMP    (1L << FILB_NEWIDCMP)
  125. #define    FILF_MULTISELECT (1L << FILB_MULTISELECT)
  126. #define    FILF_PATGAD    (1L << FILB_PATGAD)
  127.  
  128.  
  129. /* The following additional flags may be passed with the
  130.  * ASL_ExtFlags1 tag.
  131.  */
  132. #define    FIL1B_NOFILES    0L /* Do not want a file gadget, no files shown      */
  133. #define    FIL1B_MATCHDIRS    1L /* Have Patgad or rf_Pat screen files AND DIRS    */
  134.  
  135. #define    FIL1F_NOFILES    (1L << FIL1B_NOFILES)
  136. #define    FIL1F_MATCHDIRS    (1L << FIL1B_MATCHDIRS)
  137.  
  138.  
  139. /*
  140.  ************************************************************************
  141.  *    The ASL font requester data structure...            *
  142.  *                                    *
  143.  * As with the FileRequest structure, the fields documented here are    *
  144.  * for READ ACCESS ONLY.  Any modifications must be done via tags.    *
  145.  ************************************************************************
  146.  */
  147. struct FontRequester    {
  148.     APTR    fo_Reserved1[2];
  149.     struct TextAttr fo_Attr;    /* Returned TextAttr        */
  150.     UBYTE    fo_FrontPen;        /* Returned pens, if selected    */
  151.     UBYTE    fo_BackPen;
  152.     UBYTE    fo_DrawMode;
  153.     APTR    fo_UserData;
  154.     };
  155.  
  156. /* Bit defines for ASL_FuncFlags, for FONT requester            */
  157. /* See descriptive text for FILF_ values above for an overview.        */
  158. /* Note - old mixed-case defines were nonstandard, now obsolete        */
  159.  
  160. #define    FONB_FRONTCOLOR    0    /* Display Front color selector?    */
  161. #define    FONB_BACKCOLOR    1    /* Display Back color selector?        */
  162. #define    FONB_STYLES    2    /* Display Styles checkboxes?        */
  163. #define    FONB_DRAWMODE    3    /* Display DrawMode NWay?        */
  164. #define    FONB_FIXEDWIDTH    4    /* Only allow fixed-width fonts?    */
  165. #define    FONB_NEWIDCMP    5    /* Create a new IDCMP port, not shared    */
  166. #define    FONB_DOMSGFUNC    6    /* Called with Object=IntuiMessage for    */
  167.                 /*    other windows in shared port,    */
  168.                 /*   you must return Object pointer    */
  169.                 /*   and asl will reply Object for you    */
  170. #define    FONB_DOWILDFUNC    7    /* Called with Object=TextAttr to approve*/
  171.                 /*    NON-Zero return accepts        */
  172.  
  173. #define    FONF_FRONTCOLOR    (1L << FONB_FRONTCOLOR)
  174. #define    FONF_BACKCOLOR    (1L << FONB_BACKCOLOR)
  175. #define    FONF_STYLES    (1L << FONB_STYLES)
  176. #define    FONF_DRAWMODE    (1L << FONB_DRAWMODE)
  177. #define    FONF_FIXEDWIDTH    (1L << FONB_FIXEDWIDTH)
  178. #define    FONF_NEWIDCMP    (1L << FONB_NEWIDCMP)
  179. #define    FONF_DOMSGFUNC    (1L << FONB_DOMSGFUNC)
  180. #define    FONF_DOWILDFUNC    (1L << FONB_DOWILDFUNC)
  181.  
  182.  
  183. /************************************************************************/
  184. /* Arguments to AllocAslRequest()                    */
  185. /* Types of requester structures which may be allocated:        */
  186. /************************************************************************/
  187. #define    ASL_FileRequest    0
  188. #define    ASL_FontRequest    1
  189.  
  190. /************************************************************************/
  191. /* Tags for AllocAslRequest() and AslRequest()                */
  192. /************************************************************************/
  193.  
  194. #define ASL_Dummy (TAG_USER + 0x80000)
  195.  
  196. #define ASL_Hail    ASL_Dummy+1    /* Hailing text follows             */
  197. #define ASL_Window    ASL_Dummy+2    /* Parent window for IDCMP & screen  */
  198. #define    ASL_LeftEdge    ASL_Dummy+3    /* Initialize LeftEdge             */
  199. #define    ASL_TopEdge    ASL_Dummy+4    /* Initialize TopEdge             */
  200. #define    ASL_Width    ASL_Dummy+5
  201. #define    ASL_Height    ASL_Dummy+6
  202. #define    ASL_HookFunc    ASL_Dummy+7    /* Hook function pointer         */
  203.  
  204. /* Tags specific to file request                         */
  205. #define    ASL_File    ASL_Dummy+8    /* Initial name of file follows         */
  206. #define    ASL_Dir        ASL_Dummy+9    /* Initial string of filerequest dir */
  207.  
  208. /* Tags specific to font request                         */
  209. #define    ASL_FontName    ASL_Dummy+10    /* Initial font name             */
  210. #define    ASL_FontHeight    ASL_Dummy+11    /* Initial font height             */
  211. #define    ASL_FontStyles    ASL_Dummy+12    /* Initial font styles             */
  212. #define    ASL_FontFlags    ASL_Dummy+13    /* Initial font flags for textattr   */
  213. #define    ASL_FrontPen    ASL_Dummy+14    /* Initial frontpen color         */
  214. #define    ASL_BackPen    ASL_Dummy+15    /* Initial backpen color         */
  215. #define    ASL_MinHeight    ASL_Dummy+16    /* Minimum font height to display    */
  216. #define    ASL_MaxHeight    ASL_Dummy+17    /* Max font height to display         */
  217.  
  218. #define    ASL_OKText    ASL_Dummy+18    /* Text displayed in OK gadget         */
  219. #define    ASL_CancelText    ASL_Dummy+19    /* Text displayed in CANCEL gadget   */
  220. #define    ASL_FuncFlags    ASL_Dummy+20    /* Function flags, depend on request */
  221.  
  222. #define    ASL_ModeList    ASL_Dummy+21    /* Substitute list for font drawmodes */
  223. #define    ASL_ExtFlags1    ASL_Dummy+22    /* For passing extended FIL1F flags   */
  224.  
  225. #define    ASL_Pattern    ASL_FontName    /* File requester pattern string     */
  226.  
  227. /******** END of ASL Tag values    *****************************************/
  228.  
  229. #endif
  230.